认识MyBatis与Mybatis |
您所在的位置:网站首页 › sql plus使用 › 认识MyBatis与Mybatis |
一、认识Mybatis
1、功能架构 Mybatis的功能架构分为三层: (1)API接口层:提供给外部使用的接口API,开发人员通过这些本地API来操纵数据库。接口层一接收到调用请求就会调用数据处理层来完成具体的数据处理。 (2)数据处理层:负责具体的SQL查找、SQL解析、SQL执行和执行结果映射处理等。它主要的目的是根据调用的请求完成一次数据库操作。 (3)基础支撑层:负责最基础的功能支撑,包括连接管理、事务管理、配置加载和缓存处理,这些都是共用的东西,将他们抽取出来作为最基础的组件。为上层的数据处理层提供最基础的支撑。 2、框架架构 框架架构讲解: (1)加载配置:配置来源于两个地方,一处是配置文件,一处是Java代码的注解,将SQL的配置信息加载成为一个个MappedStatement对象(包括了传入参数映射配置、执行的SQL语句、结果映射配置),存储在内存中。 (2)SQL解析:当API接口层接收到调用请求时,会接收到传入SQL的ID和传入对象(可以是Map、JavaBean或者基本数据类型),Mybatis会根据SQL的ID找到对应的MappedStatement,然后根据传入参数对象对MappedStatement进行解析,解析后可以得到最终要执行的SQL语句和参数。 (3)SQL执行:将最终得到的SQL和参数拿到数据库进行执行,得到操作数据库的结果。 (4)结果映射:将操作数据库的结果按照映射的配置进行转换,可以转换成HashMap、JavaBean或者基本数据类型,并将最终结果返回。 3、MyBatis工作流程 延伸:xml文件中,insert中的参数useGeneratedKeys=true(插入数据时,返回数据的id,即返回主键) 6、MyBatis 有几种分页方式? 分页方式:逻辑分页和物理分页。 逻辑分页:使用 MyBatis 自带的 RowBounds 进行分页,它是一次性查询很多数据,然后在数据中再进行检索。弊端是需要消耗大量的内存、有内存溢出的风险,对数据库压力较大。 物理分页:自己手写 SQL 分页或使用分页插件 PageHelper,从数据库查询指定条数的数据。弥补了一次性全部查出的所有数据的种种缺点。 MyBatis 分页插件的实现原理是什么? 分页插件的基本原理是使用 MyBatis 提供的插件接口,实现自定义插件,在插件的拦截方法内拦截待执行的 SQL,然后重写 SQL,根据 dialect 方言,添加对应的物理分页语句和物理分页参数。 7、MyBatis 有三种基本的Executor执行器 a.SimpleExecutor:每执行一次 update 或 select 就开启一个 Statement 对象,用完立刻关闭 Statement 对象; b.ReuseExecutor:执行 update 或 select,以 SQL 作为 key 查找 Statement 对象,存在就使用,不存在就创建,用完后不关闭 Statement 对象,而是放置于 Map 内供下一次使用。简言之,就是重复使用 Statement 对象; c.BatchExecutor:执行 update(没有 select,jdbc 批处理不支持 select),将所有 SQL 都添加到批处理中(addBatch()),等待统一执行(executeBatch()),它缓存了多个 Statement 对象,每个 Statement 对象都是 addBatch()完毕后,等待逐一执行 executeBatch()批处理,与 jdbc 批处理相同。 8、Mybatis和Hibernate的比较 Mybatis是一个半ORM框架;Hibernate是一个全ORM框架。Mybatis需要自己编写sql。 Mybatis直接编写原生sql,灵活度高,可以严格控制sql执行性能;Hibernate的自动生成hql,因为更好的封装型,开发效率提高的同时,sql语句的调优比较麻烦。 Hibernate的hql数据库移植性比Mybatis更好,Hibernate的底层对hql进行了处理,对于数据库的兼容性更好, Mybatis直接写的原生sql都是与数据库相关,不同数据库sql不同,这时就需要多套sql映射文件。 Hibernate在级联删除的时候效率低;数据量大, 表多的时候,基于关系操作会变得复杂。 Mybatis和Hibernate都可以使用第三方缓存,而Hibernate相比Mybatis有更好的二级缓存机制。9、#{}和${}的区别是什么? #{}是预编译处理(底层使用的是PreparedStatement),防止sql注入;${}是字符串替换。 二、认识Mybatis-plus
优点 无侵入:Mybatis-Plus 在 Mybatis 的基础上进行扩展,只做增强不做改变,MyBatis-Plus支持所有Mybatis原生的特性,因此引入 Mybatis-Plus 不会对现有的 Mybatis 构架产生任何影响,而且 MP 支持所有 Mybatis 原生的特性 依赖少:仅仅依赖 Mybatis 以及 Mybatis-Spring 损耗小:启动即会自动注入基本CURD,性能基本无损耗,直接面向对象操作 通用CRUD操作:内置通用 Mapper、通用 Service,仅仅通过少量配置即可实现单表大部分 CRUD 操作,更有强大的条件构造器,满足各类使用需求 多种主键策略:支持多达4种主键策略(内含分布式唯一ID生成器),可自由配置,完美解决主键问题 支持ActiveRecord:支持 ActiveRecord 形式调用,实体类只需继承 Model 类即可实现基本 CRUD 操作 支持代码生成:采用代码或者 Maven 插件可快速生成 Mapper 、 Model 、 Service 、 Controller 层代码,支持模板引擎,更有超多自定义配置等您来使用(P.S. 比 Mybatis 官方的 Generator 更加强大!) 支持自定义全局通用操作:支持全局通用方法注入( Write once, use anywhere ) 内置分页插件:基于Mybatis物理分页,开发者无需关心具体操作,配置好插件之后,写分页等同于写基本List查询 内置性能分析插件:可输出Sql语句以及其执行时间,建议开发测试时启用该功能,能有效解决慢查询 内置全局拦截插件:提供全表 delete 、update 操作智能分析阻断,预防误操作 三、MyBatis与Mybatis-plus的区别如果Mybatis Plus是扳手,那Mybatis Generator就是生产扳手的工厂。 MyBatis:一种操作数据库的框架,提供一种Mapper类,支持让你用java代码进行增删改查的数据库操作,省去了每次都要手写sql语句的麻烦。但是!有一个前提,你得先在xml中写好sql语句,也是很麻烦的。 MP的存在就是为了稍稍弥补Mybatis的不足。在我们使用Mybatis时会发现,每当要写一个业务逻辑的时候都要在DAO层写一个方法,再对应一个SQL,即使是简单的条件查询、即使仅仅改变了一个条件都要在DAO层新增一个方法,针对这个问题,MP就提供了一个很好的解决方案,它可以让我们避免许多重复性的工作。 |
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |